package DP1;

import java.util.Arrays;
import java.util.HashMap;

/**
 * 594. 最长和谐子序列
 * 和谐数组是指一个数组里元素的最大值和最小值之间的差别正好是1。
 * 现在，给定一个整数数组，你需要在所有可能的子序列中找到最长的和谐子序列的长度
 * 输入: [1,3,2,2,5,2,3,7]
 * 输出: 5
 * 原因: 最长的和谐数组是：[3,2,2,2,3].
 */
public class Main23 {
    public static void main(String[] args) {
        int[] nums = {1,3,2,2,5,2,3,7};
        System.out.println(findLHS(nums));
    }

    public static int findLHS(int[] nums) {

        HashMap<Integer, Integer> map = new HashMap<>();
        int res = 0;
        for (int e: nums){
            map.put(e,map.getOrDefault(e,0)+1);
        }
        for (int key: map.keySet()) {// 注意map已经按照key值进行排序了
            if (map.containsKey(key + 1))
                res = Math.max(res, map.get(key) + map.get(key + 1));
        }
        return res;
    }
}
